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Problemática 


Proyecto: 

• Muchos archivos 

• Muchas revisiones 

• Muchos cambios 

• Mantenimientos 

• Actualizaciones 

• Muchos colaboradores 
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Sistema de control de 


Es una combinación de 
tecnologías y prácticas. 

Para seguir y controlar 
los cambios realizados 
en los Picheros del 
proyecto 


ersiones 




GIT 


• Un sistema de control de 
versiones distribuido. 

• No depende de acceso a la red o 
un repositorio central. 

• Enfocado a la velocidad, uso 
práctico y manejo de proyectos 
grandes. 

• Creado por Linus Torvalds, el 
creador del núcleo Linux. 





LINUX 


HAPPY birthday 


Linux Turns 25-Years-Old Today 


Distribuido 


1 . Todos son igual de importantes. 

2. Se puede trabajar sin conexión. 

3. Debes ganar confianza y confiar 
en otros. 

4. Los cambios solo te afectan a ti. 

5. Colaboración Realiza cambios sin 
afectar a los demás. Experimenta 
y ramifica el código a tu gusto. 


Centralizado 


1. Todos deben conectarse a un 
servidor central. 

2. No puedes trabajar sin conexión. 

3. Los cambios afectan a todos. 

4. Casi no envías cambios. Te 
esperas a que tengas algo 
estable para subirlo al 
repositorio. 

5. Crear ramas es muy costoso, 
tardado o tedioso. 






Distribuido 









Instalar GIT 


Instalación en distribuciones GNU/Linux de la Familia de Debían 


Debian/Ubuntu 

$ apt-get install git 

Fedora 

$ yum install git (up to Fedora 21) 

$ dnF install git (Fedora 22 and later) 

Gentoo 

$ emerge --ask --verbose dev-vcs/git 

Arch Linux 

$ pacman -S git 
openSUSE 

$ zypper install git 


$ git coníig -global user.name "John Doe" 

$ git conFig -global user.emailjohndoe@example.com 





Trabajando con GIT 


Iniciar un repositorio vacío 

$ git init 


r 




Añadir un archivo específico. 

$ git add "nombre_de_archivo" 

Añadir todos los archivos del directorio 

$ git add . 


Confirmar los cambios realizados. 

$ git commit-m "mensaje" 

Revisar estado del repositorio 

$ git status 


Working 

Directory 




/ \ 

Staging area 

v / 


f \ 

Local repo 

v J 



git commit 








Ramas 


Ver ramas de mi repositorio 

$ git branch 


/ \ 

Crear ramas Fomenta la 

experimentación y creatividad. 


Crear nueva rama 




> 


Buenas prácticas 


Feature 


Develop 

Hotfix 



<- Peer reviews 


Master 


<- Integration 
Tests 



Desarrollo colaborativc 


Si utilizas un servidor remoto 
clonando 

$ git clone username@host.xz:/path/to/repo.git 
$ git clone https://host.xz/path/to/repo.git 

Agregando a repositorio existente 
$ git remóte add origin <server> 


Recibir datos al repositorio remoto 
$ git pulí origin master 


Mandar datos al repositorio remoto 
$ git push origin master 


con Gl 


Local 


/ working / staging 

l directory ) l area II P° j 


staging 

area 


git add 
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git commit 


K 

v' 


git checkout 



git merge 

■ 


Remóte 


remóte 

repo 


git push 


git fetch 



A month in Chromium with 
Gource... 




Conflictos 




Antes de fusionar los cambios, puedes revisarlos 
usando: 

git diPP <source_branch> <target_branch> 








Ignorando archivos 


Ejemplo» .gitignore 
### Linux ### 


### Java ### 
*.class 

# Package Files # 

*.jar 

*.war 

*.ear 



gitignore. io 




Servidores GIT 



DEVELOPER A 


DEVELOPER B 




GIT Server 



GitLab 


• * • < ÜJ 


GitLab 

áfe Your Projects 

★ Starred Projects 

: S¿ Groups 

O Milestones 

O issues 3 

S Merge Requests 0 

O Help 



darby 


■ gitlab.com 


c 


Él □> o 


Dashboard 

1 Push events & Merge events «Ir Comments A Team 


Search 


© + O » 


Filter by ñame 


Marc Radulescu commented on commit 1 c5cf4d0 at GitLab.com / ww... less than a minute ago 

W 

GitLab.com / www-grtlab-com 

Q ©sytses ©Haydn FYI 1 have fixed the mailchimp link and put the sales sheet Ítem back 

A A 


where it belonged wrth: https://grtlab.com/grtlab-com/www-grtL. 


W 

GitLab.org / GitLab Community ... 

Marc Radulescu pushed to branch master at GitLab.com / www-gitla... 

2 minutes ago 

0 

GitLab.org / omnibus-gitlab 

e9263717 fixtypo 


G 

GitLab.com / GitLab.com Suppo... 

Marc Radulescu pushed to branch master at GitLab.com / www-gitla... 

5 minutes ago 

© 

GitLab.org / GitLab Cl 

Ic5cf4d0 Fix Mailchimp link 


G 

GitLab.org / GitLab Enterprise E. . . 

Sytse Sijbrandij commented on issue #1517 at GitLab.org / GitLab Co... 

5 minutes ago 

G 

GitLab.org / gitlab-ci-multi-runner 

& i; 






G 

GitLab.com / GitLab Artwork 

Marín Jankovski commented on issue #674 at GitLab.org / omnibus-gi... 

6 minutes ago 

D 

GitLab.com / doc-gitlab-com 

W This issue tracker is used to report problems with the omnibus-gitlab packages and it 



seems that you have issues with the configuration. See how to... 


G 

GitLab.org / gitlab-shell 

Marín Jankovski closed issue #674 at GitLab.org / omnibus-gitlab 

6 minutes ago 

G 

GitLab.org / gitlab-test 

Compile error in default.rb. 






L 

GitLab.org / linguist 

Jacob Vosmaer commented on issue #681 at GitLab.org / omnibus-git.. 

7 minutes ago 



O However, this doesn't work well for upgrades where gitlab.rb is already generated.... 


G 

GitLab.org / GitLab Developmen... 






GIT Fork 


Bifurcación > 

hace una copia exacta en crudo del 
repositorio original 

Independientes > 

Repositorios git idénticos pero con 
distintas URL 




O © © 0 

Fork Discuss Merge 






Herramientas GUI 


Archivo Editar Vista Ayuda 


-Iremotes/ oriqíñ^^^M Mer qe pulí reques t #3 from minka-it/wíkl-l Jorge J, Riera <jorge.riera9@gmail,com> 

n i ii m fix de falta de param« Ramiro Martínez <ramiro. daniel.ing@gmail.com> 

correcion de nombre de función Ramiro Martínez <ramiro.daniel.ing@gmail,com> 

modulo de wikipedia, pip install wikipedia Ramiro Martinez <ramiro.daniel.ing@gmail.com> 

' Realizaron inicializacion del repositorio oficial, correcciones de nombres y moc nigrobyte <jorge.riera9@gmail,com> 


i Merge pulí request #2 from sbalgas/master 
< fix errores con caracteres no ingleses, Se trabaja con UTF8 
» flx errores con caracteres no ingleses. Se trabaja con UTF8 
i Create README.md 

i, M erqe pulí request #1 from jo rqex9/chaterbot 
— Iiiiinil )iiiii|in^^^^^B base de conocimiento de SARA 
chaterbot y correciones menores 
chaterbot y correciones menores 
' agregando dirección de repositorio temporal del bot 
i subiendo ultima versión de minbo 
i Initial comm'it 


revisión |que contiene: 

jr 


o <- 1 -» | im»r 


Jorge Justino Riera <jorge.riera9@gmail.com> 
Leandro G. Ortega <sbalgass@unamed> 
Leandro G. Ortega <sbalgass@unamed> 
ramyx <ramiro,daniel.ing@gmail.com> 
ramyx <ramiro.daniel.ing@gmail.com> 

Ramiro Martinez <ramiro.daniel.ing@gmail.com> 
Ramiro Martinez <ramiro. daniel.ing@gmail.com> 
Ramiro Martinez <ramiro.daniel.ing@gmail.com> 
nigrobyte <jorge.riera9@gmail.com> 
nigrobyte <jorge.riera9@gmail.com> 

Jorge Justino Riera <jorge.riera9@gmail.com> 
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► Parche Arbol 


Diferencia Versión antigua Versión nueva Líneas de contexto: 




Rama: master . remotes/oriqin/master , remotes/oriqin/v/iki-T.oqqer-aiml2 , wiki-loqqer-aiml2 
Sigue-a: 

Precede-a: 

fix errores con caracteres no ingleses. Se trabaja con LÍTF8 

( 7ac865e..f00d516 100644 

a -6,7 +6,9 @@ BotName: minbo 

from py_expression_eval import Parser 
•import telebot, os, aiml 
i-import telebot, os, aiml, sys 
i-reload(sys) 

hsys , setdefaultencoding ( ' utf8' ) 

bot = telebot .TeleBot CTOKEN" ) 
parser = ParserO 


f¡ r Ignora cambios de e Comentarios 

— -¿j minbo-public.vl.l.py 


2016-06-02 

2016-05-29 

2016-05-29 

2016-05-29 

2016-05-27 

2016-05-22 

2016-05-22 

2016-05-22 

2016-05-21 

2016-05-21 

2016-05-20 

2016-05-20 

2016-05-20 

2016-05-20 

2016-05-20 

2016-05-20 


18:59:02 

18:21:55 

18:10:07 

18:07:27 

04:35:50 

22:08:44 

22:04:01 

22:01:32 

00:09:04 

00:00:46 

23:51:07 

23:45:09 

23:33:09 

17:47:47 

17:41:43 

17:38:41 


^ Todos los campos 




Glggle 





> Preguntas? 



> Gradas 



memegenerator.net 


Jorge J. Riera email: jorge.riera9@gmail.com 

twitter: @nigrobyte 

IRC: Preenode.net #USLJujuy @nigrobyte 


